home *** CD-ROM | disk | FTP | other *** search
/ Shareware Super Platinum 8 / Shareware Super Platinum 8.iso / mac / PROGTOOL / FGL304F.ZIP;1 / EXFOR.ARJ / FGDOC / EXAMPLES / FORTRAN / 06-12.FOR < prev    next >
Encoding:
Text File  |  1994-01-24  |  1.4 KB  |  63 lines

  1. $INCLUDE: 'C:\FG\INTRFACE.FOR'
  2.  
  3.       PROGRAM MAIN
  4.  
  5.       INTEGER*2 RECTANGLES
  6.       PARAMETER (RECTANGLES=200)
  7.  
  8.       INTEGER*2 I
  9.       INTEGER*2 MINX, MAXX, MINY, MAXY
  10.       INTEGER*2 OLD_MODE
  11.       INTEGER*2 XRES, YRES
  12.       INTEGER*2 FG_AUTOMODE, FG_GETMAXX, FG_GETMAXY, FG_GETMODE
  13.       INTEGER*2 RANDOM
  14.  
  15.       OLD_MODE = FG_GETMODE()
  16.       CALL FG_SETMODE(FG_AUTOMODE())
  17.       CALL FG_BOXDEPTH(3,3)
  18.  
  19.       XRES = FG_GETMAXX()
  20.       YRES = FG_GETMAXY()
  21.  
  22.       DO 10 I = 1,RECTANGLES
  23.          MINX = RANDOM(0,XRES)
  24.          MAXX = RANDOM(0,XRES)
  25.          MINY = RANDOM(0,YRES)
  26.          MAXY = RANDOM(0,YRES)
  27.          IF (MINX .GT. MAXX) CALL SWAP(MINX,MAXX)
  28.          IF (MINY .GT. MAXY) CALL SWAP(MINY,MAXY)
  29.          CALL FG_SETCOLOR(RANDOM(0,15))
  30.          CALL FG_BOX(MINX,MAXX,MINY,MAXY)
  31. 10    CONTINUE
  32.  
  33.       CALL FG_SETMODE(OLD_MODE)
  34.       CALL FG_RESET
  35.  
  36.       STOP ' '
  37.       END
  38.  
  39.       INTEGER*2 FUNCTION RANDOM(MIN,MAX)
  40.  
  41.       INTEGER*2 MIN, MAX
  42.       INTEGER*2 SEED, TEMP
  43.  
  44.       DATA SEED /12345/
  45.  
  46.       TEMP = IEOR(SEED,ISHFT(SEED,-7))
  47.       SEED = IAND(IEOR(ISHFT(TEMP,8),TEMP),#7FFF)
  48.       RANDOM = MOD(SEED,MAX-MIN+1) + MIN
  49.  
  50.       RETURN
  51.       END
  52.  
  53.       SUBROUTINE SWAP(VAR1,VAR2)
  54.       INTEGER*2 VAR1, VAR2
  55.       INTEGER*2 TEMP
  56.  
  57.       TEMP = VAR1
  58.       VAR1 = VAR2
  59.       VAR2 = TEMP
  60.  
  61.       RETURN
  62.       END
  63.